import {
  memo,
  useCallback,
} from 'react'
import {
  RiCloseLine,
} from '@remixicon/react'
import FileImageRender from '@/app/components/base/file-uploader/file-image-render'
import type { FileEntity } from '../types'
import ProgressCircle from '@/app/components/base/progress-bar/progress-circle'
import { ReplayLine } from '@/app/components/base/icons/src/vender/other'
import { fileIsUploaded } from '../utils'
import Button from '@/app/components/base/button'

type ImageItemProps = {
  file: FileEntity
  showDeleteAction?: boolean
  onRemove?: (fileId: string) => void
  onReUpload?: (fileId: string) => void
  onPreview?: (fileId: string) => void
}
const ImageItem = ({
  file,
  showDeleteAction,
  onRemove,
  onReUpload,
  onPreview,
}: ImageItemProps) => {
  const { id, progress, base64Url, sourceUrl } = file

  const handlePreview = useCallback((e: React.MouseEvent<HTMLDivElement>) => {
    e.stopPropagation()
    e.preventDefault()
    onPreview?.(id)
  }, [onPreview, id])

  const handleRemove = useCallback((e: React.MouseEvent<HTMLButtonElement>) => {
    e.stopPropagation()
    e.preventDefault()
    onRemove?.(id)
  }, [onRemove, id])

  const handleReUpload = useCallback((e: React.MouseEvent<HTMLDivElement>) => {
    e.stopPropagation()
    e.preventDefault()
    onReUpload?.(id)
  }, [onReUpload, id])

  return (
    <div
      className='group/file-image relative cursor-pointer'
      onClick={handlePreview}
    >
      {
        showDeleteAction && (
          <Button
            className='absolute -right-1.5 -top-1.5 z-[11] hidden h-5 w-5 rounded-full p-0 group-hover/file-image:flex'
            onClick={handleRemove}
          >
            <RiCloseLine className='h-4 w-4 text-components-button-secondary-text' />
          </Button>
        )
      }
      <FileImageRender
        className='size-8 shadow-md'
        imageUrl={base64Url || sourceUrl || ''}
      />
      {
        progress >= 0 && !fileIsUploaded(file) && (
          <div className='absolute inset-0 z-10 flex items-center justify-center border-[2px] border-effects-image-frame bg-background-overlay-alt'>
            <ProgressCircle
              percentage={progress}
              size={12}
              circleStrokeColor='stroke-components-progress-white-border'
              circleFillColor='fill-transparent'
              sectorFillColor='fill-components-progress-white-progress'
            />
          </div>
        )
      }
      {
        progress === -1 && (
          <div
            className='absolute inset-0 z-10 flex items-center justify-center border-[2px] border-state-destructive-border bg-background-overlay-destructive'
            onClick={handleReUpload}
          >
            <ReplayLine className='size-5 text-text-primary-on-surface' />
          </div>
        )
      }
    </div>
  )
}

export default memo(ImageItem)
